草庐IT

c++ - 部分排列

全部标签

docker - Heroku h18 错误,而我的后端响应 200 到他们的路由器(多部分/表单数据)

在Heroku上部署我的golangAPI时出现错误。Heroku检测到断开连接并报告500错误,而在日志中我的服务器正确回答了200。它是带有附加文件的multipart/form-data请求,我只是在响应体。2019-03-01T07:35:29.060814+00:00app[web.1]:xx.x.xx.x--[01/Mar/2019:07:35:29+0000]"POST/v1/fixture/extract/HTTP/1.1"20021332019-03-01T07:35:29.413179+00:00heroku[router]:sock=backendat=error

c - Golang cgo *C.int 大小差异

我正在探索CGO,我遇到了一个怪癖,在go运行时中C.int的大小是8个字节,但Cint是4个字节。我知道Goint可以是64位或32位,具体取决于体系结构,而Cint始终是32位。是有一种标准方法可以告诉go对C.int类型使用4个字节吗?我无法找到处理此问题的文档。因此,代码无法按预期运行。它基本上将低端添加到第一个int的高端。它从不引用传递的第二个int。提前致谢。实际输出:0xc00001a0b00xc00001a0b80xc00001a0b00xc00001a0b41990199主.gopackagemain/*intaddNums(int*nums);*/import"C

c - Windows DLL 文件的正确构建模式是什么?

这两个步骤:gcc-cmain.cgcc-oa.exemain.oMyThing.dll非常适合制作可以调用MyThing.dll内部方法的Windowsexe。注意没有-c的gccmain.c会给出如下错误:未定义对MyThing_method的引用但是,当尝试使用cgo在Golang程序中使同一个系统工作时,我遇到了与使用没有-c的gcc时相同的undefinedreference错误。我读过:https://github.com/golang/go/wiki/WindowsDLLs并且很想尝试使用syscall.NewLazyDLL但我的问题是我的foo.go文件正在调用C.So

http - 如何在请求中转义正斜杠以使 url-routers 将其计为 uri 参数的一部分?

我使用gorilla/mux进行路由映射:router.Handle("/v1/data/{param}",handler)当我调用curlhttp://localhost:8080/v1/data/hello%2Fworld时,我得到了404响应代码。问题是,在我的微服务中,我想将/v1/data/之后的所有内容解释为param。捕获参数的代码如下:uriP:=mux.Vars(r)param:=uriP["param"]是否可以使用gorilla/mux实现此目的?或任何其他路由器? 最佳答案 您应该添加正则表达式,因为默认的正

c - 如何将 Go 函数作为参数传递给 C 函数?

我正在尝试将Go函数传递给C函数。类似于:stm:=C.struct_tray_menu{....fn://definitionofmethod....}C.menu_cb(stm);并将其传递给C函数:staticvoidmenu_cb(structtray_menu*item){(void)item;printf("menu:clickedon%s\n",item->text);}我只是想知道如何定义像C.function这样的东西。 最佳答案 主要问题是对c中go定义的误解。所以最终代码看起来像//exportcallOnMe

c - 如何从 C 库中检索 probuf

我正在尝试使用GoogleProtocolBuffers与Go中的C库进行通信,但我无法使其正常工作。我在尝试将protobuf发送到C库时遇到错误我将发布最少的代码来重现我现在面临的错误(我删除了大部分C部分,因为它与此错误无关):/*#cgoCFLAGS:-I@CURRENT_SOURCE_DIR@/../../library/crnd/include-I@CMAKE_CURRENT_BINARY_DIR@/../../library#cgoLDFLAGS:-L@CRND_LIBRARY_PATH@-lcrnd#include#include#include#includetype

go - GC是否处理数组的未指向部分

假设我们以这种方式创建了一个slice:arr:=make([]byte,0,10)arr=append(arr,[]byte{1,1,1}...)然后我们要释放7个尾字节:arr=arr[:len(arr)]我们让slice的尾部无法到达。GC会在下一次扫描迭代中简单地声明此内存是免费的吗?或者底层数组会发生其他事情(例如copy(),内stub本不会被释放)? 最佳答案 Let'ssaythatwecreatedaslicethisway:arr:=make([]byte,0,10)arr=append(arr,[]byte{1

google-app-engine - Go AppEngine 重复部分执行 http.handler

funcinit(){http.HandleFunc("/",handler)}在处理程序函数中,有代码遍历数据列表、处理它并聚合结果。假设对于给定的查询,有100个项目需要处理。对于我向Appengine控制台写入日志的每个项目,“Itemnhasbeenprocessed”。问题是:请求没有返回。前40条左右的日志消息,然后重复,再重复。它总是停止相同的项目,然后重新启动。我最好的猜测是应用程序达到了内存限制或其他原因,而AppengineGo运行时只是重新启动并重新执行处理程序。对于一小部分项目,处理按预期进行,并且日志没有显示任何循环。请求日志中没有错误,但另一个日志显示:pa

go - 如何在 Go 中映射 X 的一部分?

我正在尝试使用launchpad.net/gommap来内存映射int32数组和其他一些自定义结构类型。我非常想在映射区域中的位置使用它们。gommap.Mmap类型是[]byte,我怎样才能使它的部分作为其他类型的slice可用? 最佳答案 你必须使用不安全的包。funcmapInt32(fduintptr,protgommap.ProtFlags,flagsgommap.MapFlags)([]int32,error){mmap,err:=gommap.Map(fd,prot,flags)iferr!=nil{returnnil

c - 将 go linker 构建为独立工具

关闭。这个问题需要更多focused.它目前不接受答案。想改进这个问题吗?更新问题,使其只关注一个问题editingthispost.关闭8年前。Improvethisquestion我正在浏览go源代码,我想将其构建为osx的独立链接器,可以生成mach-o文件。有办法做到这一点吗?